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1  Instalación 

1.1  Windows 

#  Instalación  en  Windows 

#  Instalación  mediante  interfaz  gráfica 
pwd 

Is  -la 

git  --versión 


git  versión  2.1.4 

1.2  Linux 

#  Instalación  en  Ubuntu 

#  Comprobación  de  que  Git  no  esté  instalado 

git 

sudo  apt-get  update 
sudo  apt-get  upgrade 
sudo  apt-get  install  git 
git  -versión 


git  versión  2.1.4 


#  Opcional.  Instalación  de  todos  los  subpaquetes  complementarios 
sudo  apt-get  install  git-all 


#  Instalación  en  Ubuntu  mediante  PPA 

#  Comprobación  de  que  Git  no  esté  instalado 
git 

sudo  add-apt- reposi tory  ppa : gi t-core/ppa 
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sudo  apt-get  update 
sudo  apt-get  install  git 

#  Si  ya  lo  tuviéramos  instalado  solo  tendríamos  que  ejecutar  para 

#  tener  la  versión  de  Git  actualizada 
sudo  apt-get  upgrade 


#  Instalación  en  CentOS 

#  Comprobación  de  que  Git  no  esté  instalado 

git 

sudo  yum  upgrade 
sudo  yum  install  git 
git  --versión 


git  versión  2.1.4 


#  Opcional.  Instalación  de  todos  los  subpaquetes  complementarios 
sudo  yum  install  git-all 

1.3  OS  X 

#  Instalación  en  OS  X 

#  Instalación  mediante  interfaz  gráfica 
pwd 

Is  -la 

git  --versión 


git  versión  2.1.4 


#  Instalación  en  OS  X 

#  Instalación  mediante  MacPorts 
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sudo  port  install  git-core  +svn  +doc  +bash_completion  +gitweb 
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2  Primeros  pasos 

2.1  Ayuda 

git 


#  Distintas  formas  de  obtener  ayuda 

git  help  init 

git  init  --help 

man  git  init 

man  git-init 


#  Lista  completa  con  todos  los  subcomandos  disponibles 
git  help  -a 

#  Lista  con  las  guias  de  conceptos  más  habituales 
git  help  -g 

#  Ejemplo  de  la  guia  de  conceptos  “glossary” 
git  help  glossary 
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2.2  Configuración  inicial 

#  Configuro  el  nombre  del  usuario  a  nivel  de  usuario 
git  config  --global  user.name  "Fonte  Learn" 

#  Configuro  la  dirección  de  correo  electrónico 
git  config  --global  user. email  test@fontelearn.com 

#  Configuro  emacs  como  editor 

git  config  --global  core. editor  emacs 

#  Configuro  notepad.exe  como  editor  en  Windows 
git  config  --global  core. editor  notepad.exe 

#  Configuro  vim  como  editor 

git  config  --global  core. editor  vim 

#  Configuro  vimdiff  para  mostrar  las  diferencias  entre  dos  archivos 

#  y  como  herramienta  de  resolución  de  conflictos 

git  config  --global  diff.tool  vimdiff 
git  config  --global  merge.tool  vimdiff 

#  Configuro  la  salida  para  que  se  muestre  con  colores 
git  config  --global  color. ui  true 

#  Configuro  las  conversiones  de  final  de  linea 

#  Solo  necesario  en  sistemas  Windows 
git  config  --global  core . autocrlf  true 

#  Configuro  que  solo  se  convierta  el  final  de  linea  en  la  entrada 
git  config  --global  core . autocrlf  input 

#  Muestro  la  configuración  de  Git 
git  config  --list 

user . name=Fonte  Learn 

user .email=test@fontelearn . com 

core.editor=vim 

merge . tool=vi mdi ff 

color . ui =true 
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3  Ejemplos 

3.1  Clonando  un  repositorio 

#  git  clone  URL  [directorio] 

#  Accedo  a  https://github.com/jquery/jquery  con  el  navegador 
mkdir  -/proyectos/ 

cd  -/proyectos/ 

git  clone  https://github.com/jquery/jquery.git 

Clonar  en  «jquery»... 

remóte:  Counting  objects:  38320,  done. 

remóte:  Compressing  objects:  100%  (79/79),  done. 

remóte:  Total  38320  (delta  44),  reused  0  (delta  0),  pack-reused  38241 
Receiving  objects:  100%  (38320/38320),  23.17  Mi B  |  514.00  KiB/s,  done. 
Resolving  deltas:  100%  (27073/27073),  done. 

Checking  connecti vi ty . . .  hecho. 

Is 

j  query 

Is  jquery  -a  -1 


AUTHORS.txt 
bui  Id 

CONTRIBUTING . md 
. edi torconfi g 
external 

•git 

•gitattributes 

•gitignore 

Gruntfi le . j  s 
.  jscsrc 
. j  shi nti gnore 
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.  j  shi ntrc 
LICENSE.txt 
. mai Imap 
. npmi gnore 
package . j son 
README.md 
src 
test 

. travi s . yml 

cd  jquery 

git  log  --format= '  9áCred%h?óCreset  -9áC(yellow)9ád?áCreset  ?ós 
%Cgreen (?ócr)  '  - -abbrev-commi t  --date=relative  -10 

47ccf3d  -  (HEAD,  ori gi n/master ,  origin/HEAD,  master)  Attributes:  do  not  set 
properties  to  false  when  removing  booleans  (hace  23  horas) 

15ac848  -  Core:  make  isNumeric  limited  to  strings  and  numbers  (hace  23  horas) 

1144e75  -  Build:  Add  "deprecated"  to  the  Testswarm  module  list  (hace  2  días) 

e99a3ac  -  Tests:  Add  Safari  9  support  tests  results  (hace  4  dias) 

487d5ca  -  CSS:  Correct  misrepresentation  of  "auto"  horizontal  margins  as  0 
(hace  4  dias) 

c752a50  -  Attributes:  fix  tablndex  on  <img>  in  IE11  (hace  4  dias) 

3689963  -  CSS:  use  isFinite  in  place  of  redundant  isNumeric  (hace  4  dias) 
9090d98  -  Core:  add  unit  test  for  i sPlai nObj ect (Symbol)  (hace  4  dias) 

32cfc38  -  CSS:  fix  AMD  mode  for  the  new  showHide  module  (hace  4  dias) 

9f9e204  -  Offset:  allow  small  differences  in  offset. top  (hace  4  dias) 

cd  -/proyectos/ 

git  clone  https://github.com/jquery/jquery.git  mi_jquery 

Clonar  en  «mi_jquery» . . . 

remóte:  Counting  objects:  38320,  done. 

remóte:  Compressing  objects:  10096  (79/79),  done. 

remóte:  Total  38320  (delta  44),  reused  0  (delta  0),  pack-reused  38241 
Receiving  objects:  10096  (38320/38320),  23.17  Mi B  |  516.00  KiB/s,  done. 
Resolving  deltas:  10096  (27073/27073),  done. 

Checking  connecti vi ty . . .  hecho. 
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Is  -1 

j query 
mi_jquery 

3.2  A  partir  de  un  proyecto  existente 

cd  -/proyectos/ 

#  Creo  un  directorio  y  accedo  a  él 
mkdir  proyecto_exi stente 

cd  proyecto_exi stente 

#  Creo  dos  archivos  nuevos 
touch  archivo_a.txt 
touch  archivo_b.txt 

Is  -1 

archi vo_a . txt 
archi vo_b . txt 

git  init 

Initialized  empty  Git  repository  in 
/home/usuari o/ proyectos/ proyecto_exi stente/ .git/ 

Is  -a  -1 

archi vo_a . txt 
archi vo_b . txt 
•git 

tree  .git 

•git 

| -  branches 

| -  config 

| -  description 

| -  HEAD 
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hooks 

| -  applypatch-msg.sample 

| -  commi t-msg . sample 

| -  post-update . sample 

| -  pre-applypatch . sample 

| -  pre-commi t . sample 

| -  prepare-commit-msg. sample 

| -  pre-push . sample 

| -  pre- rebase . sample 

1 -  update . sample 

i  nfo 

1 -  exelude 

objeets 

| -  i  nfo 

1 -  pack 

refs 

| -  heads 

1 -  tags 


git  status 


En  la  rama  master 


Commi t  inicial 


Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 


archivo_a.txt 
archivo  b.txt 


no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento  (use 
«git  add»  para  darle  seguimiento) 


3.3  A  partir  de  un  proyecto  nuevo 

#  Creo  un  directorio  y  accedo  a  él 
mkdi r  ~/proyectos/proyecto_nuevo/ 
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cd  ~/proyectos/proyecto_nuevo/ 
git  status 

fatal:  Not  a  git  repository  (or  any  of  the  parent  di rectories) :  .git 

Is  -a  -1 


git  init 

Initialized  empty  Git  repository  in 
/home/usuari o/proyectos/proyecto_nuevo/ .git/ 

Is  -a  -1 

•git 


3.4  Añadiendo  un  primer  archivo 

touch  archivo_a.txt 
Is  -la 


archi vo_a . txt 
•git 

git  status 

En  la  rama  master 

Commit  inicial 

Archivos  sin  seguimiento: 
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(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

archivo_a.txt 

no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento  (use 
«git  add»  para  darle  seguimiento) 

git  add  archivo_a.txt 

#  git  add  . 
git  status 

En  la  rama  master 

Commit  inicial 

Cambios  para  hacer  commit: 

(use  «git  rm  --cached  <archivo> . . .«  para  eliminar  stage) 

new  file:  archivo_a.txt 

3.5  Primer  commit 

git  commit  -m  "Añado  el  archivo_a.txt  vacio" 

[master  ( root-commi t)  b4383e5]  Añado  el  archivo_a.txt  vacio 
1  file  changed,  0  i nserti ons (+) ,  0  deletions(-) 
create  mode  100644  archivo_a.txt 

git  status 

En  la  rama  master 

nothing  to  commit,  working  directory  clean 

#  git  commit  ->  abre  el  editor  predefinido 

3.6  Añadiendo  más  archivos 

touch  archivo_b.txt 
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touch  archivo_c.txt 
git  status 

En  la  rama  master 

Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

archivo_b.txt 

archivo_c.txt 

no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento  (use 
«git  add»  para  darle  seguimiento) 

git  add  archivo_b.txt 
git  status 

En  la  rama  master 

Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

new  file:  archivo_b.txt 

Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

archivo_c.txt 

git  commit  -m  "Añado  el  archivo_b.txt  vacio" 

[master  d59b4d4]  Añado  el  archivo_b.txt  vacio 
1  file  changed,  0  i nserti ons (  +  ) ,  0  deletions(-) 
create  mode  100644  archivo_b.txt 

git  status 

En  la  rama  master 

Archivos  sin  seguimiento: 
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(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

archivo_c.txt 

no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento  (use 
«git  add»  para  darle  seguimiento) 

git  add  . 
git  status 

En  la  rama  master 

Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

new  file:  archivo_c.txt 

git  commit 

#  Se  abre  el  editor  por  defecto  (vim) 

#  Please  enter  the  commit  message  for  your  changes.  Lines  starting 

#  with  '#'  will  be  ignored,  and  an  empty  message  aborts  the  commit. 

#  En  la  rama  master 

#  Cambios  para  hacer  commit: 

#  new  file:  archivo_c.txt 

Edito  el  mensaje 

Añado  el  archivo_c.txt  vacio 

#  Please  enter  the  commit  message  for  your  changes.  Lines  starting 

#  with  '#'  will  be  ignored,  and  an  empty  message  aborts  the  commit. 

#  En  la  rama  master 

#  Cambios  para  hacer  commit: 

#  new  file:  archivo_c.txt 

y  guardo  el  archivo 

Tecla  "Esc" 

:  wq 
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[master  Idea6e3]  Añado  el  archivo_c.txt  vacio 
1  file  changed,  0  i nserti ons (+) ,  0  deleti ons ( - ) 
create  mode  100644  archivo_c.txt 

#  Para  ver  los  commits  realizados,  uno  por  linea 
git  log  --oneline 

Idea6e3  Añado  el  archivo_c.txt  vacio 

d59b4d4  Añado  el  archivo_b.txt  vacio 

b4383e5  Añado  el  archivo_a.txt  vacio 

3.7  Editando  archivos 

echo  "Creo  una  primera  linea  en  archivo_a.txt"  >>  archivo_a.txt 
git  status 

En  la  rama  master 

Cambios  no  preparados  para  el  commit: 

(use  «git  add  <archi vo> . . . »  para  actualizar  lo  que  se  ejecutará) 

(use  «git  checkout  --  <archi vo> . . . «  para  descartar  cambios  en  le  directorio 
de  trabajo) 

modified:  archivo_a.txt 

no  hay  cambios  agregados  al  commit  (use  «git  add»  o  «git  commit  -a») 

git  add  archivo_a.txt 
git  status 

En  la  rama  master 

Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

modified:  archivo_a.txt 

echo  "Creo  una  primera  linea  en  el  archivo_b.txt"  >>  archivo_b.txt 
echo  "Creo  una  primera  linea  en  el  archivo_c.txt"  >>  archivo_c.txt 
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git  status 

En  la  rama  master 

Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

modified:  archivo_a.txt 

Cambios  no  preparados  para  el  commit: 

(use  «git  add  <archi vo> . . . »  para  actualizar  lo  que  se  ejecutará) 

(use  «git  checkout  --  <archi vo> . . . «  para  descartar  cambios  en  le  directorio 
de  trabajo) 

modified:  archivo_b.txt 

modified:  archivo_c.txt 

git  add  archivo_b.txt 
git  status 

En  la  rama  master 

Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

modified:  archivo_a.txt 

modified:  archivo_b.txt 

Cambios  no  preparados  para  el  commit: 

(use  «git  add  <archi vo> . . . »  para  actualizar  lo  que  se  ejecutará) 

(use  «git  checkout  --  <archi vo> . . . «  para  descartar  cambios  en  le  directorio 
de  trabajo) 

modified:  archivo_c.txt 

git  commit  -m  "Introduzco  una  linea  en  los  archivos  archivo_a.txt  y 
archi vo_b . txt" 

[master  4fdd4e4]  Introduzco  una  linea  en  los  archivos  archivo_a.txt  y 
archi vo_b . txt 

2  files  changed,  2  insertions(+) 
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git  status 

En  la  rama  master 

Cambios  no  preparados  para  el  commit: 

(use  «git  add  <archi vo> . . . »  para  actualizar  lo  que  se  ejecutará) 

(use  «git  checkout  --  <archi vo> . . . «  para  descartar  cambios  en  le  directorio 
de  trabajo) 

modified:  archivo_c.txt 

no  hay  cambios  agregados  al  commit  (use  «git  add»  o  «git  commit  -a») 

git  log  --oneline 

4fdd4e4  Introduzco  una  linea  en  los  archivos  archivo_a.txt  y  archivo_b.txt 
Idea6e3  Añado  el  archivo_c.txt  vacio 
d59b4d4  Añado  el  archivo_b.txt  vacio 
b4383e5  Añado  el  archivo_a.txt  vacio 

git  add  archivo_c.txt 

git  commit  -m  "Introduzco  una  linea  en  el  archivo  archivo_c.txt" 

[master  c51caal]  Introduzco  una  linea  en  el  archivo  archivo_c.txt 
1  file  changed,  1  insertion(+) 

git  status 

En  la  rama  master 

nothing  to  commit,  working  directory  clean 

git  log  --oneline 

c51caal  Introduzco  una  linea  en  el  archivo  archivo_c.txt 

4fdd4e4  Introduzco  una  linea  en  los  archivos  archivo_a.txt  y  archivo_b.txt 
Idea6e3  Añado  el  archivo_c.txt  vacio 
d59b4d4  Añado  el  archivo_b.txt  vacio 
b4383e5  Añado  el  archivo_a.txt  vacio 
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3.8  Borrando  archivos 

touch  temporal_l.txt 
touch  temporal_2.txt 
git  status 

En  la  rama  master 

Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

temporal_l.txt 

temporal_2.txt 

no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento  (use 
«git  add»  para  darle  seguimiento) 

git  add  . 
git  status 

En  la  rama  master 

Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

new  file:  temporal_l.txt 
new  file:  temporal_2.txt 

git  commit  -m  "Añado  dos  archivos  de  prueba  para  borrar" 

2  files  changed,  0  i nsertions (+) ,  0  deletions(-) 
create  mode  100644  temporal_l.txt 
create  mode  100644  temporal_2.txt 

rm  temporal_l.txt 
git  status 

En  la  rama  master 

Cambios  no  preparados  para  el  commit: 

(use  «git  add/rm  <archivo> . . . »  para  actualizar  lo  que  se  ejecutará) 
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(use  «git  checkout  --  <archi vo> .  .  . «  para  descartar  cambios  en  le  directorio 
de  trabajo) 

deleted:  temporal_l.txt 

no  hay  cambios  agregados  al  commit  (use  «git  add»  o  «git  commit  -a») 
git  rm  temporal_l.txt 
rm  'temporal_l.txt' 
git  status 

En  la  rama  master 

Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

deleted:  temporal_l.txt 

git  commit  -m  "Borro  el  archivo  temporal_l.txt" 

[master  91b6dda]  Borro  el  archivo  temporal_l.txt 
1  file  changed,  0  i nserti ons (+) ,  0  deletions(-) 
delete  mode  100644  temporal_l.txt 

git  status 

En  la  rama  master 

nothing  to  commit,  working  directory  clean 

3.9  Borrando  archivos  (II) 

git  rm  temporal_2.txt 
rm  'temporal_2.txt' 
git  status 
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En  la  rama  master 

Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archivo> . . .«para  eliminar  stage) 

deleted:  temporal_2.txt 

git  commit  -m  "Borro  el  archivo  temporal_2.txt" 

[master  b5b78cc]  Borro  el  archivo  temporal_2.txt 
1  file  changed,  0  i nserti ons (  +  ) ,  0  deletions(-) 
delete  mode  100644  temporal_2.txt 

3.10  Renombrando  y  moviendo  archivos 

touch  temporal_3.txt 
touch  temporal_4.txt 
touch  temporal_5.txt 
git  status 

En  la  rama  master 

Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

temporal_3 . txt 
temporal_4 . txt 
temporal_5 . txt 

no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento  (use 
«git  add»  para  darle  seguimiento) 

#  Ponemos  los  3  archivos  bajo  seguimiento 
git  add  . 
git  status 

En  la  rama  master 

Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 
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new  file:  temporal_3.txt 

new  file:  temporal_4.txt 

new  file:  temporal_5.txt 

git  commit  -m  "Añado  tres  archivos  de  prueba  para  moverlos" 

[master  63a453b]  Añado  tres  archivos  de  prueba  para  moverlos 
3  files  changed,  0  i nsertions (+) ,  0  deletions(-) 
create  mode  100644  temporal_3.txt 
create  mode  100644  temporal_4.txt 
create  mode  100644  temporal_5.txt 

mv  temporal_3.txt  temporal_3_movido.txt 
git  status 

En  la  rama  master 

Cambios  no  preparados  para  el  commit: 

(use  «git  add/rm  <archi vo> . . . »  para  actualizar  lo  que  se  ejecutará) 

(use  «git  checkout  --  <archi vo> . . . «  para  descartar  cambios  en  le  directorio 
de  trabajo) 

deleted:  temporal_3.txt 

Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

tempo ral_3_movi do . txt 

no  hay  cambios  agregados  al  commit  (use  «git  add»  o  «git  commit  -a») 

git  rm  temporal_3.txt 

rm  'temporal_3.txt' 

git  add  temporal_3_movido.txt 
git  status 
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En  la  rama  master 

Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

renamed:  temporal_3.txt  ->  temporal_3_movido.txt 

3.11  Renombrando  y  moviendo  archivos  (II) 

git  mv  temporal_4.txt  temporal_4_movido.txt 
git  status 

En  la  rama  master 
Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

renamed:  temporal_4.txt  ->  temporal_3_movido.txt 

renamed:  temporal_3.txt  ->  temporal_4_movido.txt 

mkdir  dir_temp 
git  status 

En  la  rama  master 
Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

renamed:  temporal_4.txt  ->  temporal_3_movido.txt 

renamed:  temporal_3.txt  ->  temporal_4_movido.txt 

git  mv  temporal_5.txt  di r_temp/temporal_5 . txt 
git  status 

En  la  rama  master 
Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

renamed:  temporal_5.txt  ->  di r_temp/temporal_5 . txt 

renamed:  temporal_4.txt  ->  temporal_3_movido.txt 
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renamed:  temporal_3.txt  ->  temporal_4_movido.txt 

git  commit  -m  "Renombramos  tres  archivos" 

[master  44a9a8c]  Renombramos  tres  archivos 
3  files  changed,  0  i nsertions (  +  ) ,  0  deletions(-) 
rename  temporal_5.txt  =>  di r_temp/temporal_5 . txt  (10096) 
rename  temporal_4.txt  =>  temporal_3_movido.txt  (10096) 
rename  temporal_3.txt  =>  temporal_4_movido.txt  (10096) 

3.12  Ignorar  archivos 

touch  temporal_6.txt 
touch  temporal_7.zip 
mkdir  log 

touch  log/apache . log 
touch  log/apache . logl 
mkdir  imágenes 
touch  imagenes/fondo. png 
touch  imagenes/logo. png 
mkdir  compilados 
touch  compilados/salida. o 
touch  compilados/salida . a 
touch  .gitignore 
git  status 

En  la  rama  master 

Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

.gitignore 

compilados/ 

imágenes/ 

log/ 

temporal_6 . txt 
temporal_7 . zi p 
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no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento  (use 
«git  add»  para  darle  seguimiento) 

git  clean  -df 

Eliminando  .gitignore 
Eliminando  compilados/ 

Eliminando  imágenes/ 

Eliminando  log/ 

Eliminando  temporal_6.txt 
Eliminando  temporal_7.zip 

git  status 

En  la  rama  master 

nothing  to  commit,  working  directory  clean 

touch  temporal_6.txt 
touch  temporal_7.zip 
mkdir  log 

touch  log/apache . log 
touch  log/apache . logl 
mkdir  imágenes 
touch  imagenes/fondo. png 
touch  imagenes/logo.png 
mkdir  compilados 
touch  compilados/salida. o 
touch  compilados/salida . a 
touch  .gitignore 
git  status 

En  la  rama  master 
Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 
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. gitignore 
compilados/ 
imágenes/ 
log/ 

temporal_6 . txt 
temporal_7 . zi p 

no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento 
«git  add»  para  darle  seguimiento) 

#  Añadimos  el  archivo  "temporal_6.txt"  y  el  "temporal_7.zip" 
echo  "temporal_6.txt"  >>  .gitignore 

echo  "temporal_7.zip"  >>  .gitignore 
git  status 

En  la  rama  master 
Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

.gitignore 

compilados/ 

imágenes/ 

log/ 

no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento 
«git  add»  para  darle  seguimiento) 

#  Añadimos  todos  los  archivos  . zip  y  . gz  en  el  directorio  raiz 
echo  "*.zip"  >>  .gitignore 

echo  "*.gz"  >>  .gitignore 
git  status 

En  la  rama  master 
Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

.gitignore 


(use 


(use 
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compilados/ 

imágenes/ 

log/ 

no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento  (use 
«git  add»  para  darle  seguimiento) 

#  Añadimos  los  archivos  de  log  que  están  en  el  directorio  "log" 
echo  "log/*. log"  >>  .gitignore 

#  Añadimos  los  archivos  de  rotación  de  log  que  están  en  el 
directorio  "log" 

echo  "log/* . log[0-9] "  >>  .gitignore 
git  status 

En  la  rama  master 
Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

.gitignore 

compilados/ 

imágenes/ 

no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento  (use 
«git  add»  para  darle  seguimiento) 

#  Añadimos  todo  el  contenido  del  directorio  "imágenes" 
echo  "imágenes/*"  >>  .gitignore 

git  status 

En  la  rama  master 
Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

.gitignore 

compilados/ 

no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento  (use 
«git  add»  para  darle  seguimiento) 
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#  Excepto  el  archivo  "logo.png" 

echo  " ! imagenes/logo . png"  >>  .gitignore 
git  status 

En  la  rama  master 
Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

. gi ti gnore 

compilados/ 

imágenes/ 

no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento  (use 
«git  add»  para  darle  seguimiento) 

#  Añadimos  los  archivos  compilados 
echo  "compilados/* [ao] "  >>  .gitignore 
git  status 

En  la  rama  master 
Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

.gitignore 

imágenes/ 

no  se  ha  agregado  nada  al  commit  pero  existen  archivos  sin  seguimiento  (use 
«git  add»  para  darle  seguimiento) 

git  add  . 
git  status 

En  la  rama  master 
Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

new  file:  .gitignore 
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new  file:  imagenes/logo. png 

git  commit  -m  "Añado  el  archivo  .gitignore  y  el  archivo 
imagenes/logo .png" 

2  files  changed,  9  i nsertions (+) 
create  mode  100644  .gitignore 
create  mode  100644  imagenes/logo . png 

git  status 

En  la  rama  master 

nothing  to  commit,  working  directory  clean 
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3.13  Crear  una  rama 

cd  -/proyectos/ 
mkdir  proyecto_ramas 
cd  proyecto_ramas 
git  init 

Initialized  empty  Git  repository  in 
/home/usuari o/proyectos/proyecto_ramas/ .git/ 

touch  archivo_a.txt 
git  add  . 

git  commit  -m  "Añado  el  primer  archivo" 

[master  ( root-commi t)  015be45]  Añado  el  primer  archivo 
1  file  changed,  0  i nserti ons (+) ,  0  deletions(-) 
create  mode  100644  archivo_a.txt 

touch  archivo_b.txt 
git  add  . 

git  commit  -m  "Añado  el  segundo  archivo" 

[master  3323879]  Añado  el  segundo  archivo 
1  file  changed,  0  i nserti ons (+) ,  0  deletions(-) 
create  mode  100644  archivo_b.txt 

git  log  --oneline 

3323879  Añado  el  segundo  archivo 
015be45  Añado  el  primer  archivo 

git  branch 

*  master 

Is  -a  -1  .git 
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branches 

COMMIT_EDITMSG 

confi g 

descri pti on 

HEAD 

hooks 

i  ndex 

i  nfo 

logs 

obj  ects 

refs 

cat  .git/HEAD 

ref:  refs/heads/master 

Is  -a  -1  .git/refs/heads/ 

master 

cat  . gi t/refs/heads/master 

33238797baafcb47c385fe20b9df011cf6e6e4f8 

git  log  --format=format:?óH  -1 

33238797baafcb47c385fe20b9df011cf6e6e4f8 

git  branch  pruebas 
git  branch 

*  master 

pruebas 

Is  -a  -1  .git/refs/heads/ 
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master 

pruebas 

cat  .git/refs/heads/pruebas 

33238797baafcb47c385fe20b9df011cf6e6e4f8 

cat  .git/refs/heads/master 

33238797baafcb47c385fe20b9df011cf6e6e4f8 

3.14  Mostrar  las  ramas 

git  branch 

*  master 
pruebas 

git  branch  -r 


git  branch  -a 

*  master 
pruebas 

3.15  Cambiarse  de  rama 

git  branch 

*  master 
pruebas 

cat  .git/HEAD 

ref:  refs/heads/master 
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git  checkout  pruebas 

Switched  to  branch  'pruebas' 

git  branch 

master 

*  pruebas 

cat  .git/HEAD 

ref:  refs/heads/pruebas 


3.16  Trabajando  con  una  rama 

git  checkout  pruebas 

Ya  está  en  «pruebas» 

echo  "Inserto  una  linea  en  el  archivo_a.txt"  >>  archi vo_a . txtgi t 
commit  -am  "Introduzco  una  linea  en  el  archivo  archivo_a.txt" 

[pruebas  583503e]  Introduzco  una  linea  en  el  archivo  archivo_a.txt 
1  file  changed,  1  insertion(+) 

git  log  --oneline 

583503e  Introduzco  una  linea  en  el  archivo  archivo_a.txt 
3323879  Añado  el  segundo  archivo 
015be45  Añado  el  primer  archivo 

cat  archivo_a.txt 

Inserto  una  linea  en  el  archivo_a.txt 

git  checkout  master 
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Switched  to  branch  'master' 

cat  archivo_a.txt 

git  log  --oneline 

3323879  Añado  el  segundo  archivo 
015be45  Añado  el  primer  archivo 

git  checkout  pruebas 

Switched  to  branch  'pruebas' 
git  log  --oneline 

583503e  Introduzco  una  linea  en  el  archivo  archivo_a.txt 
3323879  Añado  el  segundo  archivo 
015be45  Añado  el  primer  archivo 

3.17  Crear  y  cambiar  a  una  rama 

#  git  checkout  master 

#  git  branch  [nombre_de_la_rama] 

#  git  checkout  [nombre_de_la_rama] 


git  checkout  master 

Switched  to  branch  'master' 

git  checkout  -b  experimento 

Switched  to  a  new  branch  'experimento' 

echo  "Experimento  añadiendo  una  nueva  linea  al  archivo_a.txt  en  la 
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rama  experimento"  >>  archivo_a.txt 
git  status 

En  la  rama  experimento 

Cambios  no  preparados  para  el  commit: 

(use  «git  add  <archi vo> . . . »  para  actualizar  lo  que  se  ejecutará) 

(use  «git  checkout  --  <archi vo> . .  . «  para  descartar  cambios  en  le  directorio 
de  trabajo) 

modified:  archivo_a.txt 

no  hay  cambios  agregados  al  commit  (use  «git  add»  o  «git  commit  -a») 

git  commit  -am  "Experimentando  con  una  nueva  linea  en  el 
archivo_a.txt  en  la  rama  experimento" 

[experimento  bb6104a]  Experimentando  con  una  nueva  linea  en  el  archivo_a.txt 
en  la  rama  experimento 

1  file  changed,  1  insertion(+) 

git  log  --oneline 

bb6104a  Experimentando  con  una  nueva  linea  en  el  archivo_a.txt  en  la  rama 
experimento 

3323879  Añado  el  segundo  archivo 
015be45  Añado  el  primer  archivo 

cat  archivo_a.txt 

Experimento  añadiendo  una  nueva  linea  al  archivo_a.txt  en  la  rama  experimento 

git  checkout  master 
git  log  --oneline 

3323879  Añado  el  segundo  archivo 
015be45  Añado  el  primer  archivo 

cat  archivo_a.txt 
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git  checkout  pruebas 
git  log  --oneline 

583503e  Introduzco  una  linea  en  el  archivo  archivo_a.txt 
3323879  Añado  el  segundo  archivo 
015be45  Añado  el  primer  archivo 

cat  archivo_a.txt 

Inserto  una  linea  en  el  archivo_a.txt 

git  log  --oneline  --graph  --all  --decórate 

*  bb6104a  (experimento)  Experimentando  con  una  nueva  linea  en  el  archivo_a.txt 
|  *  583503e  (HEAD,  pruebas)  Introduzco  una  linea  en  el  archivo  archivo_a.txt 
1/ 

*  3323879  (master)  Añado  el  segundo  archivo 

*  015be45  Añado  el  primer  archivo 

3.18  Renombrar  una  rama 

#  git  branch  -m  [nombre_actual]  [nombre_nuevo] 
git  branch 

experimento 

master 

*  pruebas 

git  branch  -m  experimento  intento 
git  branch 

intento 

master 

*  pruebas 
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3.19  Borrar  una  rama 

#  git  branch  -d  [nombre_de_la_rama] 
git  checkout  master 

git  branch  rama_temporal 
git  branch 

intento 

*  master 
pruebas 
rama_temporal 

git  checkout  rama_temporal 
git  branch  -d  rama_temporal 

error:  Cannot  delete  the  branch  ' rama_temporal '  which  you  are  currently  on. 

git  checkout  master 

git  branch  -d  rama_temporal 

Deleted  branch  rama_temporal  (was  3323879) . 

git  branch 

i ntento 

*  master 
pruebas 

3.20  Fusionar  ramas 

#  git  merge 
git  branch 

i ntento 

*  master 
pruebas 
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git  log  --oneline  --graph  --all  --decórate 

*  bb6104a  (intento)  Experimentando  con  una  nueva  linea  en  el  archivo_a.txt  en 
|  *  583503e  (pruebas)  Introduzco  una  linea  en  el  archivo  archivo_a.txt 

1/ 

*  3323879  (HEAD,  master)  Añado  el  segundo  archivo 

*  015be45  Añado  el  primer  archivo 

git  checkout  master 
git  merge  intento 

Updating  3323879 .. bb6104a 
Fast-forward 

archivo_a.txt  |  1  + 

1  file  changed,  1  insertion(+) 

git  log  --oneline  --graph  --all  --decórate 

*  bb6104a  (HEAD,  master,  intento)  Experimentando  con  una  nueva  linea  en  el 
|  *  583503e  (pruebas)  Introduzco  una  linea  en  el  archivo  archivo_a.txt 

1/ 

*  3323879  Añado  el  segundo  archivo 

*  015be45  Añado  el  primer  archivo 

git  checkout  master 
cat  archivo_a.txt 

Experimento  añadiendo  una  nueva  linea  al  archivo_a.txt  en  la  rama  experimento 

git  checkout  master 

echo  "Añado  una  segunda  linea  al  archivo_a.txt  en  la  rama  master"  >> 
archi vo_a . txt 

git  commit  -am  "Añado  una  segunda  linea  al  archivo_a.txt  en  la  rama 
master" 

[master  b831151]  Añado  una  segunda  linea  al  archivo_a.txt  en  la  rama  master 
1  file  changed,  1  insertion(+) 
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git  checkout  intento 

echo  "Añado  una  primera  linea  al  archivo_b.txt  en  la  rama  intento" 
>>  archivo_b.txt 

git  commit  -am  "Añado  una  primera  linea  al  archivo_b.txt  en  la  rama 
i ntento" 

[intento  157b399]  Añado  una  primera  linea  al  archivo_b.txt  en  la  rama  intento 
1  file  changed,  1  insertion(+) 

git  log  --oneline  --graph  --all  --decórate 

*  157b399  (HEAD,  intento)  Añado  una  primera  linea  al  archivo_b.txt  en  la  rama 
|  *  b831151  (master)  Añado  una  segunda  linea  al  archivo_a.txt  en  la  rama 

1/ 

*  bb6104a  Experimentando  con  una  nueva  linea  en  el  archivo_a.txt  en  la  rama 
|  *  583503e  (pruebas)  Introduzco  una  linea  en  el  archivo  archivo_a.txt 

1/ 

*  3323879  Añado  el  segundo  archivo 

*  015be45  Añado  el  primer  archivo 

git  checkout  master 
git  merge  intento 

Merge  made  by  the  'recursive'  strategy. 

archivo_b.txt  |  1  + 

1  file  changed,  1  insertion(+) 

git  checkout  master 
cat  archivo_b.txt 

Añado  una  primera  linea  al  archivo_b.txt  en  la  rama  intento 

git  log  --oneline  --graph  --all  --decórate 

*  2e4da58  (HEAD,  master)  Merge  branch  'intento' 

l\ 

|  *  157b399  (intento)  Añado  una  primera  linea  al  archivo_b.txt  en  la  rama 
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*  |  b831151  Añado  una  segunda  linea  al  archivo_a.txt  en  la  rama  master 

1/ 

*  bb6104a  Experimentando  con  una  nueva  linea  en  el  archivo_a.txt  en  la  rama 
|  *  583503e  (pruebas)  Introduzco  una  linea  en  el  archivo  archivo_a.txt 

1/ 

*  3323879  Añado  el  segundo  archivo 

*  015be45  Añado  el  primer  archivo 

3.21  Conflictos  en  la  fusión  entre  ramas 

git  checkout  master 
cat  archivo_a.txt 

Experimento  añadiendo  una  nueva  linea  al  archivo_a.txt  en  la  rama  experimento 
Añado  una  segunda  linea  al  archivo_a.txt  en  la  rama  master 

git  checkout  pruebas 
cat  archivo_a.txt 

Inserto  una  linea  en  el  archivo_a.txt 

git  checkout  master 
git  merge  pruebas 

Automezclado  archivo_a.txt 

CONFLICTO (contenido) :  conflicto  de  fusión  en  archivo_a.txt 
Automatic  merge  failed;  fix  conflicts  and  then  commit  the  result. 
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git  status 

En  la  rama  master 
Tiene  rutas  sin  fusionar. 

(solucione  los  conflictos  y  ejecute  «git  commit») 

Rutas  no  combinadas: 

(use  «git  add  <archi vo> . . . »  para  marcar  resolución) 

modificado  por  ambos:  archivo_a.txt 

no  hay  cambios  agregados  al  commit  (use  «git  add»  o  «git  commit  -a») 

cat  archivo_a.txt 

<<<<<<<  HEAD 

Experimento  añadiendo  una  nueva  linea  al  archivo_a.txt  en  la  rama  experimento 
Añado  una  segunda  linea  al  archivo_a.txt  en  la  rama  master 


Inserto  una  linea  en  el  archivo_a.txt 
>>>>>>>  pruebas 

git  merge  --abort 
git  status 

En  la  rama  master 

nothing  to  commit,  working  directory  clean 

cat  archivo_a.txt 

Experimento  añadiendo  una  nueva  linea  al  archivo_a.txt  en  la  rama  experimento 
Añado  una  segunda  linea  al  archivo_a.txt  en  la  rama  master 

#  Volvemos  a  llevar  a  cabo  la  fusión 
git  checkout  master 
git  merge  pruebas 
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Automezclado  archivo_a.txt 

CONFLICTO (contenido)  :  conflicto  de  fusión  en  archivo_a.txt 
Automatic  merge  failed;  fix  conflicts  and  then  commit  the  result. 

cat  archivo_a.txt 

<<<<<<<  HEAD 

Experimento  añadiendo  una  nueva  linea  al  archivo_a.txt  en  la  rama  experimento 
Añado  una  segunda  linea  al  archivo_a.txt  en  la  rama  master 


Inserto  una  linea  en  el  archivo_a.txt 
>>>>>>>  pruebas 

#  Edito  el  archivo 

echo  "Resuelvo  el  conflicto  en  esta  primera  linea  del  archivo_a.txt" 
>  archivo_a.txt 

echo  "También  modifico  la  segunda  linea  del  archivo_a.txt"  >> 
archi vo_a . txt 

cat  archivo_a.txt 

Resuelvo  el  conflicto  en  esta  primera  linea  del  archivo_a.txt 
También  modifico  la  segunda  linea  del  archivo_a.txt 

git  status 

En  la  rama  master 
Tiene  rutas  sin  fusionar. 

(solucione  los  conflictos  y  ejecute  «git  commit») 

Rutas  no  combinadas: 

(use  «git  add  <archi vo> . . . »  para  marcar  resolución) 

modificado  por  ambos:  archivo_a.txt 

no  hay  cambios  agregados  al  commit  (use  «git  add»  o  «git  commit  -a») 

git  add  archivo_a.txt 
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git  status 

En  la  rama  master 

Todos  los  conflictos  solucionados  pero  aún  se  está  fusionando 
(use  «git  commit»  para  concluir  la  fusión) 

Cambios  para  hacer  commit: 

modified:  archivo_a.txt 

git  commit  -m  "Resuelto  el  conflicto  en  la  linea  1  en  el 
archi vo_a . txt" 

[master  6f46ed0]  Resuelto  el  conflicto  en  la  linea  1  en  el  archivo_a.txt 

git  log  --oneline  --graph  --all  --decórate  -6 

*  6f46ed0  (HEAD,  master)  Resuelto  el  conflicto  en  la  linea  1  en  el 

l\ 

|  *  583503e  (pruebas)  Introduzco  una  linea  en  el  archivo  archivo_a.txt 

*  |  2e4da58  Merge  branch  'intento' 

l\  \ 

|  *  |  157b399  (intento)  Añado  una  primera  linea  al  archivo_b.txt  en  la  rama 

*  |  |  b831151  Añado  una  segunda  linea  al  archivo_a.txt  en  la  rama  master 

1/  / 

*  |  bb6104a  Experimentando  con  una  nueva  linea  en  el  archivo_a.txt  en  la  rama 

1/ 

3.22  Rebase 

mkdi r  ~/proyectos/proyecto_rebase 
cd  ~/proyectos/proyecto_rebase 
git  init 

Initialized  empty  Git  repository  in 
/home/usuari o/ proyectos/ proyecto_ rebase/ .git/ 

touch  archivo_l.txt 


44 


Git.  Fundamentos.  Guión  de  comandos  27/10/2015 


git  add  . 

git  commit  -m  "Commit  inicial" 


git  checkout  -b  rama_l 

echo  "Linea  1"  >>  archivo_l.txt 

git  commit  -am  "Añado  una  linea" 


git  checkout  master 

echo  "Linea  1"  >>  archivo_2.txt 

git  add  . 

git  commit  -m  "Añado  un  nuevo  archivo" 


git  merge  rama_l 


git  log  --oneline  --graph  --aLL  --decórate 


*  c38al22  (HEAD,  master)  Merge  branch  'rama_l' 

l\ 

|  *  ce52c8a  (rama_l)  Añado  una  linea 

*  |  7f5ba8e  Añado  un  nuevo  archivo 

1/ 

*  d6bl012  Commit  inicial 

3.23  Rebase  (II) 

mkdi r  ~/proyectos/proyecto_rebase_2 
cd  ~/proyectos/proyecto_rebase_2 
git  init 
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touch  archivo_l.txt 
git  add  . 

git  commit  -m  "Commit  inicial" 


git  checkout  -b  rama_l 

echo  "Linea  1"  >>  archivo_l.txt 

git  commit  -am  "Añado  una  linea" 


echo  "Linea  2"  >>  archivo_l.txt 

git  commit  -am  "Añado  una  segunda  linea" 


echo  "Linea  3"  >>  archivo_l.txt 

git  commit  -am  "Añado  una  tercera  linea" 


git  checkout  master 

echo  "Linea  1"  >>  archivo_2.txt 

git  add  . 

git  commit  -m  "Añado  un  nuevo  archivo" 
git  log  --oneline  --graph  --all  --decórate 


*  697dab8  (HEAD,  master)  Añado  un  nuevo  archivo 
|  *  f81da58  (rama_l)  Añado  una  tercera  linea 

|  *  2a65cel  Añado  una  segunda  linea 
|  *  9241aad  Añado  una  linea 
1/ 

*  acede8b  Commit  inicial 

git  checkout  rama_l 
git  rebase  master 
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First,  rewinding  head  to  replay  your  work  on  top  of  it... 
Applying:  Añado  una  linea 
Applying:  Añado  una  segunda  linea 
Applying:  Añado  una  tercera  linea 

git  log  --oneline  --graph  --all  --decórate 

*  c7db69d  (HEAD,  rama_l)  Añado  una  tercera  linea 

*  479d3ea  Añado  una  segunda  linea 

*  7178441  Añado  una  linea 

*  697dab8  (master)  Añado  un  nuevo  archivo 

*  acede8b  Commit  inicial 

git  checkout  master 
git  merge  rama_l 

Updating  697dab8 . . c7db69d 
Fast-forward 
archivo_l.txt  |  3  +++ 

1  file  changed,  3  i nserti ons (+) 

git  log  --oneline  --graph  --all  --decórate 

*  c7db69d  (HEAD,  rama_l,  master)  Añado  una  tercera  linea 

*  479d3ea  Añado  una  segunda  linea 

*  7178441  Añado  una  linea 

*  697dab8  Añado  un  nuevo  archivo 

*  acede8b  Commit  inicial 

3.24  Stash 

mkdir  ~/proyectos/proyecto_stash 
cd  ~/proyectos/proyecto_stash 
git  init 

git  branch  rama_l 

fatal:  El  nombre  del  objeto  no  es  válido:  «master». 
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echo  "Primera  linea  del  archivo_l.txt"  >>  archivo_l.txt 
git  add  . 

git  commit  -m  "Commit  inicial" 

echo  "Segunda  linea  del  archivo_l.txt"  >>  archivo_l.txt 
echo  "Primera  linea  del  archivo_2.txt"  >>  archivo_2.txt 
Is  -a  -1 

archi vo_l . txt 
archi vo_2 . txt 
■git 

#  Supongamos  que  tenemos  una  interrupción 
git  status 

En  la  rama  master 

Cambios  no  preparados  para  el  commit: 

(use  «git  add  <archi vo> . . . »  para  actualizar  lo  que  se  ejecutará) 

(use  «git  checkout  --  <archi vo> . .  . «  para  descartar  cambios  en  le  directorio 
de  trabajo) 

modified:  archivo_l.txt 

Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  lo  que  se  ha  de  ejecutar) 

archivo_2.txt 

no  hay  cambios  agregados  al  commit  (use  «git  add»  o  «git  commit  -a») 

#  Tenemos  un  archivo  con  cambios  y  otro  sin  estar  bajo  seguimiento 
git  add  archivo_2.txt 

git  status 

En  la  rama  master 
Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 
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new  file:  archivo_2.txt 

Cambios  no  preparados  para  el  commit: 

(use  «git  add  <archi vo> . . . »  para  actualizar  lo  que  se  ejecutará) 

(use  «git  checkout  --  <archi vo> . . . «  para  descartar  cambios  en  le  directorio 
de  trabajo) 

modified:  archivo_l.txt 

cat  archivo_l.txt 

Primera  linea  del  archivo_l.txt 
Segunda  linea  del  archivo_l.txt 

cat  archivo_2.txt 

Primera  linea  del  archivo_2.txt 

#  Almacenamos  estos  cambios  en  el  área  de  stash 
git  stash 

Saved  working  directory  and  Índex  State  WIP  on  master:  7644181  Commit  inicial 
HEAD  is  now  at  7644181  Commit  inicial 

Is  -a  -1 

archi vo_l . txt 
•git 

cat  archivo_l.txt 

Primera  linea  del  archivo_l.txt 

git  stash 

No  hay  cambios  locales  que  guardar 
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git  stash  list 

stash@{0}:  WIP  on  master:  7644181  Commit  inicial 

git  stash  show  stash@{0} 

archivo_l.txt  |  1  + 
archivo_2.txt  |  1  + 

2  files  changed,  2  i nsertions (+) 

git  stash  show  stash@{0}  -p 

diff  --git  a/archi vo_l . txt  b/archi vo_l . txt 
Índex  34c5dll . . 19265bl  100644 

-  a/archivo_l.txt 

+++  b/archi vo_l . txt 

@@  -1  +1,2  @@ 

Primera  linea  del  archivo_l.txt 
+Segunda  linea  del  archivo_l.txt 
diff  --git  a/archivo_2 .txt  b/archivo_2 .txt 
new  file  mode  100644 
Índex  0000000 .. b054e56 

-  /dev/null 

+++  b/archi vo_2 . txt 
@@  -0,0  +1  @@ 

+Primera  línea  del  archivo_2.txt 

git  checkout  -b  rama_l 
Is  -a  -1 

archi vo_l . txt 
•git 

git  stash  apply  stash@{0} 

En  la  rama  rama_l 

Cambios  para  hacer  commit: 
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(use  «git  reset  HEAD  <archi vo> . . . «para  eliminar  stage) 

new  file:  archivo_2.txt 

Cambios  no  preparados  para  el  commit: 

(use  «git  add  <archi vo> . . . »  para  actualizar  lo  que  se  ejecutará) 

(use  «git  checkout  --  <archi vo> . . . «  para  descartar  cambios  en  le  directorio 
de  trabajo) 

modified:  archivo_l.txt 


git  stash  list 


stash@{0}:  WIP  on  master:  7644181  Commit  inicial 

git  stash  drop  stash@{0} 

Dropped  stash@{0}  (34cabdbl7aa8437df93dad59f6b057013aaca910) 

git  stash  list 
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4  Servidor 

4.1  Usuario  1 

mkdi r  ~/proyectos/proyecto_compartido 
cd  ~/proyectos/proyecto_compartido 
git  init 

touch  index.html 

echo  "Simulación  del  archivo  index.html"  >>  index.html 
touch  style.css 

echo  "Simulación  del  archivo  style.css"  >>  style.css 
git  add  . 

git  commit  -m  "Commit  inicial.  Añado  el  index.html  y  el  style.css" 

[master  ( root-commi t)  2f8837b]  Commit  inicial.  Añado  el  index.html  y  el 
style . css 

2  files  changed,  2  i nsertions (+) 
create  mode  100644  index.html 
create  mode  100644  style.css 

git  tag  -a  vO.0.1  -m  "Commit  inicial" 

git  checkout  -b  dev 

touch  todo.txt 

touch  .gitignore 

echo  "todo.txt"  >>  .gitignore 

git  add  .gitignore 

git  commit  -m  "Añado  el  archivo  .gitignore" 

[dev  Id259a5]  Añado  el  archivo  .gitignore 
1  file  changed,  1  insertion(+) 
create  mode  100644  .gitignore 

git  remóte  add  origin 

https : //ami ei ro@bi tbucket . org/ami ei ro/ proyecto -compar ti  do . git 

//  git  remóte  add  origin  gi t@bi tbucket . org : ami ei ro/proyecto- 
compartido.git 
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git  push  -u  origin  master 

Password  for  'https://amieiro@bitbucket.org': 

Counting  objects:  4,  done. 

Compressing  objects:  100%  (2/2),  done. 

Writing  objects:  100%  (4/4),  358  bytes  |  0  bytes/s,  done. 

Total  4  (delta  0) ,  reused  0  (delta  0) 

To  https : //ami ei ro@bi tbucket . org/ami ei ro/ proyecto -compar ti  do . gi t 

*  [new  branch]  master  ->  master 

Branch  master  set  up  to  track  remóte  branch  master  from  origin. 

git  branch  -a 

*  dev 
master 

remotes/origi n/master 

git  push  -u  origin  dev 

Password  for  ' https : //amiei ro@bi tbucket . org ' : 

Counting  objects:  3,  done. 

Compressing  objects:  100%  (2/2),  done. 

Writing  objects:  100%  (3/3),  337  bytes  |  0  bytes/s,  done. 

Total  3  (delta  0) ,  reused  0  (delta  0) 
remóte : 

remóte:  Create  pulí  request  for  dev: 

remóte :  https : / / bi tbucket .org/ ami ei ro/ proyecto- comparti do/pull- requests/new? 

source=dev&t=l 

remóte: 

To  https : / /ami ei ro@bi tbucket .org/ami ei ro/ proyecto- comparti do . gi t 

*  [new  branch]  dev  ->  dev 

Branch  dev  set  up  to  track  remóte  branch  dev  from  origin. 

git  branch  -a 

*  dev 
master 

remotes /o  r i gi n/dev 
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remotes /o ri gi n/master 

git  push  --tags 

Password  for  'https://amieiro@bitbucket.org': 

Counting  objects:  1,  done. 

Writing  objects:  100%  (1/1),  168  bytes  |  0  bytes/s,  done. 

Total  1  (delta  0) ,  reused  0  (delta  0) 

To  https: //amiei ro@bi tbucket . org/ami ei ro/ proyecto- compartido. git 
*  [new  tag]  V0.0.1  ->  V0.0.1 

4.2  Usuario  2 

adduser  jesusamieiro 
sudo  su  jesusamieiro 


git  config  --global  user. email  "jesus@jesusamieiro.com" 
git  config  --global  user. ñame  "desús  Amieiro" 
cd  ~ 
pwd 

mkdir  -/proyectos 
cd  -/proyectos 

git  clone  https: //JesusAmiei ro@bi tbucket . org/ami ei ro/proyecto- 
compartido.git 

Clonar  en  «proyecto-compartido»... 

Password  for  '  https://3esusAmiei ro@bitbucket.org' : 
remóte:  Counting  objects:  8,  done, 
remóte:  Compressing  objects:  100%  (5/5),  done, 
remóte:  Total  8  (delta  0),  reused  0  (delta  0) 

Unpacking  objects:  100%  (8/8),  done. 

Checking  connecti vi ty . . .  hecho. 

cd  proyecto-compartido 
git  branch  -a  -v 
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*  master  2f8837b  Commit  inicial.  Añado  el  index.html  y  el 

style . css 

remotes/origin/HEAD  ->  ori gi n/master 

remotes/origin/dev  Id259a5  Añado  el  archivo  .gitignore 

remotes/origin/master  2f8837b  Commit  inicial.  Añado  el  index.html  y  el 
style . css 


git  checkout  -b  dev  origin/dev 

Branch  dev  set  up  to  track  remóte  branch  dev  from  origin. 
Switched  to  a  new  branch  'dev' 


git  branch  -a  -v 


*  dev 

master 
style . css 

remotes/origin/HEAD 

remotes / o  ri gi n/dev 

remotes / o  ri gi n /mas te 
style . css 


Id259a5  Añado  el  archivo 
2f 8837b  Commit  inicial. 

->  origin/master 
Id259a5  Añado  el  archivo 
2f 8837b  Commit  inicial. 


. gi ti gnore 

Añado  el  index.html  y  el 


. gi ti gnore 

Añado  el  index.html  y  el 


mkdir  img 
cd  img/ 

touch  logo.png 
touch  logo.xcf 

cd  .  . 

echo  "img/*.png"  >>  .gitignore 
git  status 

En  la  rama  dev 

Su  rama  está  actualizada  con  «origin/dev». 

Cambios  no  preparados  para  el  commit: 

(use  «git  add  <archi vo> . . . »  para  actualizar  lo  que  se  confirmará) 

(use  «git  checkout  --  <archi vo> . . . »  para  descartar  cambios  en  el  directorio 
de  trabajo) 

modificado:  .gitignore 
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Archivos  sin  seguimiento: 

(use  «git  add  <archi vo> . . . »  para  incluir  en  lo  que  se  ha  de  confirmar) 

img/ 

no  hay  cambios  agregados  al  commit  (use  «git  add»  o  «git  commit  -a») 

git  add  .gitignore 
git  add  img/logo.xcf 
git  status 

En  la  rama  dev 

Su  rama  está  actualizada  con  «origin/dev». 

Cambios  para  hacer  commit: 

(use  «git  reset  HEAD  <archi vo> . . . »  para  sacar  del  stage) 

modificado:  .gitignore 

nuevo  archivo:  img/logo.xcf 

git  commit  -m  "Añado  el  logo  y  modifico  el  .gitignore" 

[dev  5ae9a02]  Añado  el  logo  y  modifico  el  .gitignore 
2  files  changed,  1  insertion(+) 
create  mode  100644  img/logo.xcf 

git  checkout  master 

Switched  to  branch  'master' 

Su  rama  está  actualizada  con  «origin/master». 

git  merge  dev 

Updating  2f8837b . . 5ae9a02 
Fast-forward 
.gitignore  |  2  ++ 
img/logo.xcf  |  0 
2  files  changed,  2  i nsertions (+) 
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create  mode  100644  .gitignore 
create  mode  100644  img/logo.xcf 

git  push  -all 

Password  for  '  https://3esusAmiei ro@bitbucket.org' : 

Counting  objects:  5,  done. 

Compressing  objects:  100%  (2/2),  done. 

Writing  objects:  100%  (5/5),  443  bytes  |  0  bytes/s,  done. 

Total  5  (delta  0) ,  reused  0  (delta  0) 

To  https : //lesusAmi ei ro@bi tbucket . org/ ami ei ro/proyecto-comparti do . gi t 
Id259a5 . . 5ae9a02  dev  ->  dev 
2f8837b . . 5ae9a02  master  ->  master 

4.3  Usuario  1 

git  checkout  master 

Switched  to  branch  'master' 

Su  rama  está  actualizada  con  «origin/master». 

git  pulí  --all 

Fetching  origin 

Password  for  'https://amieiro@bitbucket.org': 
remóte:  Counting  objects:  5,  done, 
remóte:  Compressing  objects:  100%  (2/2),  done, 
remóte:  Total  5  (delta  0),  reused  0  (delta  0) 

Unpacking  objects:  100%  (5/5),  done. 

De  https : / / bi tbucket . org/ ami ei ro/proyecto-comparti do 
2f8837b . . 5ae9a02  master  ->  origin/master 

Id259a5 . . 5ae9a02  dev  ->  origin/dev 

Updating  2f8837b . . 5ae9a02 
Fast-forward 
.gitignore  |  2  ++ 
img/logo.xcf  |  0 
2  files  changed,  2  i nsertions (+) 
create  mode  100644  .gitignore 
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create  mode  100644  img/logo.xcf 

cat  .gitignore 

todo . txt 
img/*.png 

git  branch  -a  -v 

dev  Id259a5  [behind  1]  Añado  el  archivo  .gitignore 

*  master  5ae9a02  Añado  el  logo  y  modifico  el  .gitignore 

remotes/origin/dev  5ae9a02  Añado  el  logo  y  modifico  el  .gitignore 

remotes/origin/master  5ae9a02  Añado  el  logo  y  modifico  el  .gitignore 

git  checkout  dev 

Switched  to  branch  'dev' 

Your  branch  is  behind  'origin/dev'  by  1  commit,  and  can  be  fast-forwarded . 
(use  "git  pulí"  to  update  your  local  branch) 

git  pulí 

Password  for  'https://amieiro@bitbucket.org': 

Updating  Id259a5 . . 5ae9a02 
Fast-forward 
.gitignore  |  1  + 
img/logo.xcf  |  0 
2  files  changed,  1  insertion(+) 
create  mode  100644  img/logo.xcf 

git  branch  -a  -v 

*  dev  5ae9a02  Añado  el  logo  y  modifico  el  .gitignore 

master  5ae9a02  Añado  el  logo  y  modifico  el  .gitignore 

remotes/origin/dev  5ae9a02  Añado  el  logo  y  modifico  el  .gitignore 

remotes/origin/master  5ae9a02  Añado  el  logo  y  modifico  el  .gitignore 
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mkdir  js/ 
cd  js/ 

touch  j query-2 . 1 . 0 . mi n . j s 
cd  .  . 
git  add  . 

git  commit  -m  "Añado  el  archivo  jquery-2 . 1 . 0 . mi n .  j s" 

[dev  5a30a8f]  Añado  el  archivo  j query-2 . 1 . 0 . mi n . j s 
1  file  changed,  0  i nserti ons (+) ,  0  deleti ons ( - ) 
create  mode  100644  j s/j query-2 . 1 . 0 . mi n . j s 

git  checkout  master 

Switched  to  branch  'master' 

Su  rama  está  actualizada  con  «origi n/master» . 

git  merge  dev 

Updating  5ae9a02 . . 5a30a8f 
Fast-forward 

js/jquery-2.1.0.min. js  |  0 

1  file  changed,  0  i nserti ons (+) ,  0  deletions(-) 
create  mode  100644  j s/j query-2 . 1 . 0 . mi n . j s 

git  push  --all 

Password  for  'https://amieiro@bitbucket.org': 

Counting  objects:  3,  done. 

Compressing  objects:  100%  (2/2),  done. 

Writing  objects:  100%  (3/3),  339  bytes  |  0  bytes/s,  done. 

Total  3  (delta  1) ,  reused  0  (delta  0) 

To  https : //ami ei ro@bi tbucket . org/ami ei ro/ proyecto -compartido . gi t 
5ae9a02 . . 5a30a8f  dev  ->  dev 
5ae9a02 . . 5a30a8f  master  ->  master 
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4.4  Usuario  2 


git  fetch 

Password  for  '  https://3esusAmiei ro@bitbucket.org' : 
remóte:  Counting  objects:  3,  done, 
remóte:  Compressing  objects:  10096  (2/2),  done, 
remóte:  Total  3  (delta  1),  reused  0  (delta  0) 
Unpacking  objects:  10096  (3/3),  done. 

De  https : //bi tbucket . org/ami ei ro/ proyecto -compartí do 
5ae9a02 . . 5a30a8f  master  ->  origin/master 

5ae9a02 . . 5a30a8f  dev  ->  origin/dev 

git  branch  -a  -v 


dev 

. gitignore 

*  master 
.gitignore 

remotes/origin/HEAD 

remotes/origin/dev 


5ae9a02  [behind  1]  Añado  el  logo  y  modifico  el 
5ae9a02  [behind  1]  Añado  el  logo  y  modifico  el 
->  origin/master 

5a30a8f  Añado  el  archivo  j query-2 . 1 . 0 . mi n . j s 


remotes/origin/master  5a30a8f  Añado  el  archivo  j query-2 . 1 . 0 . mi n . j s 


git  merge  origin/master 


Updating  5ae9a02 . . 5a30a8f 
Fast-forward 

js/jquery-2.1.0.min. js  |  0 

1  file  changed,  0  i nserti ons (+) ,  0  deletions(-) 
create  mode  100644  j s/j query-2 . 1 . 0 . mi n . j s 


git  branch  -a  -v 


dev 

.gitignore 
*  master 


5ae9a02  [behind  1]  Añado  el  logo  y  modifico  el 


5a30a8f  Añado  el  archivo  j query-2 . 1 . 0 . mi n . j s 
remotes/origin/HEAD  ->  origin/master 

remotes/origin/dev  5a30a8f  Añado  el  archivo  j query-2 . 1 . 0 . mi n . j s 

remotes/origin/master  5a30a8f  Añado  el  archivo  j query-2 . 1 . 0 . mi n . j s 
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git  checkout  dev 

git  checkout  dev 
git  merge  origin/dev 

git  merge  origin/dev 

Updating  5ae9a02 . . 5a30a8f 
Fast-forward 

js/jquery-2.1.0.min. js  |  0 

1  file  changed,  0  i nserti ons (+) ,  0  deletions(-) 
create  mode  100644  j s/ jquery-2 . 1 . 0 . mi n . j s 
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